package com.sg.model.po;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.sg.framework.common.annotations.LikeFlag;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotNull;
import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serial;
import java.io.Serializable;
import java.util.Date;

/**
 * 主表。有批次
 *
 * @author xxx
 */
@Data
@Accessors(chain = true)
@TableName("oms_project")  //3-7-03项目表（后面改为项目辅表）
public class OmsProject implements Serializable {

  @Serial
    private static final long serialVersionUID = 1L;

  /**
   * 项目ID
   */
  @TableId(value = "project_id", type = IdType.ASSIGN_UUID)
  @NotNull(message = "projectId不能为空")
  private String projectId;

  /**
   * 项目风险点
   */
  @TableField(value = "project_risk")
  @Schema(description = "项目风险点")
  private String projectRisk;

  /**
   * 计划开始时间
   */
  @TableField(value = "plan_start_time")
  @NotNull(message = "计划开始时间不能为空")
  @Schema(description = "计划开始时间")
  private Date planStartTime;

  /**
   * 最近里程碑ID
   */
  @TableField(value = "last_milepost_id")
  @Schema(description = "最近里程碑ID")
  private String lastMilepostId;

  /**
   * 项目规模 LARGE:大型项目 MEDIUM:中型项目 SMALL:小型项目
   */
  @TableField(value = "project_scale")
  @Schema(description = "项目规模")
  private String projectScale;

  /**
   * 内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "table_type_code")
  @Schema(description = "内容表类型编码")
  private String tableTypeCode;

  /**
   * 项目进展状态 NOT_AT_THE:未开始 ONGOING:进行中 HAS_ENDED:已结束
   */
  @TableField(value = "task_status")
  @NotNull(message = "项目进展状态不能为空")
  @Schema(description = "项目进展状态")
  private String taskStatus;

  /**
   * 项目结项状态 OPEN_ITEMS:未结项 CLOSED_ITEMS:已结项
   */
  @TableField(value = "knot_status")
  @Schema(description = "项目结项状态")
  private String knotStatus;

  /**
   * 开启项目绩效 TRUE:是 FALSE:否
   */
  @TableField(value = "open_performance")
  @Schema(description = "开启项目绩效")
  private String openPerformance;

  /**
   * 结算方式
   */
  @TableField(value = "settlement_method")
  @Schema(description = "结算方式")
  private String settlementMethod;

  /**
   * 归属主体排序
   */
  @TableField(value = "order_number")
  @NotNull(message = "归属主体排序不能为空")
  @Schema(description = "归属主体排序")
  private Long orderNumber;

  /**
   * 安排主体ID
   */
  @TableField(value = "arrange_subject_id")
  @NotNull(message = "安排主体ID不能为空")
  @Schema(description = "安排主体ID")
  private String arrangeSubjectId;

  /**
   * 系统对接应用类型编码
   */
  @TableField(value = "docking_app_type_code")
  @Schema(description = "系统对接应用类型编码")
  private String dockingAppTypeCode;

  /**
   * 主体生命周期 CURRENTLY_VALID:当前有效 EDITING:正在编辑 ARCHIVING:历史存档
   */
  @TableField(value = "subject_life_cycle")
  @NotNull(message = "主体生命周期不能为空")
  @Schema(description = "主体生命周期")
  private String subjectLifeCycle;

  /**
   * 项目编号
   */
  @TableField(value = "project_number")
  @Schema(description = "项目编号")
  private String projectNumber;

  /**
   * 项目问题及必要性
   */
  @TableField(value = "project_question")
  @Schema(description = "项目问题及必要性")
  private String projectQuestion;

  /**
   * 计划结束时间
   */
  @TableField(value = "plan_end_time")
  @NotNull(message = "计划结束时间不能为空")
  @Schema(description = "计划结束时间")
  private Date planEndTime;

  /**
   * 冗余最新进度
   */
  @TableField(value = "percentage_progress")
  @NotNull(message = "冗余最新进度不能为空")
  @Schema(description = "冗余最新进度")
  private Double percentageProgress;

  /**
   * 项目优先级 P0:P0 P1:P1 P2:P2 P3:P3 P4:P4
   */
  @TableField(value = "project_priority")
  @Schema(description = "项目优先级")
  private String projectPriority;

  /**
   * 内容表主键ID
   */
  @TableField(value = "entity_id")
  @Schema(description = "内容表主键ID")
  private String entityId;

  /**
   * 是否系统项目 TRUE:是 FALSE:否
   */
  @TableField(value = "is_system_task")
  @Schema(description = "是否系统项目")
  private String isSystemTask;

  /**
   * 结项时间
   */
  @TableField(value = "knot_time")
  @Schema(description = "结项时间")
  private Date knotTime;

  /**
   * 成员身份是否锁定修改 TRUE:是 FALSE:否
   */
  @TableField(value = "membership_is_locked_revise")
  @Schema(description = "成员身份是否锁定修改")
  private String membershipIsLockedRevise;

  /**
   * 费用结算引擎ID
   */
  @TableField(value = "project_settlement_modeld")
  @Schema(description = "费用结算引擎ID")
  private String projectSettlementModeld;

  /**
   * 安排主体类型编码 OMS_ORG_ORGANIZATION:组织表 OMS_ORG_DEPT:部门表
   */
  @TableField(value = "arrange_subject_type_code")
  @NotNull(message = "安排主体类型编码不能为空")
  @Schema(description = "安排主体类型编码")
  private String arrangeSubjectTypeCode;

  /**
   * 系统对接应用ID
   */
  @TableField(value = "docking_app_id")
  @Schema(description = "系统对接应用ID")
  private String dockingAppId;

  /**
   * 是否存档 TRUE:是 FALSE:否
   */
  @TableField(value = "is_archive")
  @NotNull(message = "是否存档不能为空")
  @Schema(description = "是否存档")
  private String isArchive;

  /**
   * 相关人数量
   */
  @TableField(value = "relevant_people_num")
  @NotNull(message = "相关人数量不能为空")
  @Schema(description = "相关人数量")
  private Long relevantPeopleNum;

  /**
   * 项目标识
   */
  @TableField(value = "project_code")
  @NotNull(message = "项目标识不能为空")
  @Schema(description = "项目标识")
  private String projectCode;

  /**
   * 项目目标价值
   */
  @TableField(value = "project_target")
  @Schema(description = "项目目标价值")
  private String projectTarget;

  /**
   * 实际开始时间
   */
  @TableField(value = "actual_start_time")
  @Schema(description = "实际开始时间")
  private Date actualStartTime;

  /**
   * 当前主流程ID
   */
  @TableField(value = "current_process_id")
  @Schema(description = "当前主流程ID")
  private String currentProcessId;

  /**
   * 项目类型 PRE_SALES_PROJECT:售前项目 PRODUCE_PROJECT:生产项目 AFTER_SALES_PROJECT:售后项目
   */
  @TableField(value = "project_type_code")
  @Schema(description = "项目类型")
  private String projectTypeCode;

  /**
   * 是否系统完成 TRUE:是 FALSE:否
   */
  @TableField(value = "is_system_complete")
  @Schema(description = "是否系统完成")
  private String isSystemComplete;

  /**
   * 父内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "parent_table_type_code")
  @Schema(description = "父内容表类型编码")
  private String parentTableTypeCode;

  /**
   * 业务应用标识
   */
  @TableField(value = "biz_app_code")
  @NotNull(message = "业务应用标识不能为空")
  @Schema(description = "业务应用标识")
  private String bizAppCode;

  /**
   * 接收部门ID
   */
  @TableField(value = "receive_subject_id")
  @NotNull(message = "接收部门ID不能为空")
  @Schema(description = "接收部门ID")
  private String receiveSubjectId;

  /**
   * 是否需要结项报告 TRUE:是 FALSE:否
   */
  @TableField(value = "is_require_knot_report")
  @Schema(description = "是否需要结项报告")
  private String isRequireKnotReport;

  /**
   * 是否自定义结算额 TRUE:是 FALSE:否
   */
  @TableField(value = "is_settlemen_amount")
  @Schema(description = "是否自定义结算额")
  private String isSettlemenAmount;

  /**
   * 存档时间
   */
  @TableField(value = "archive_time")
  @Schema(description = "存档时间")
  private Date archiveTime;

  /**
   * 项目名称
   */
  @TableField(value = "project_name")
  @NotNull(message = "项目名称不能为空")
  @Schema(description = "项目名称")
  @LikeFlag(likeType = "LIKE")
  private String projectName;

  /**
   * 项目范围
   */
  @TableField(value = "project_scope")
  @Schema(description = "项目范围")
  private String projectScope;

  /**
   * 实际结束时间
   */
  @TableField(value = "actual_end_time")
  @Schema(description = "实际结束时间")
  private Date actualEndTime;

  /**
   * 所在子流程ID
   */
  @TableField(value = "sub_process_id")
  @Schema(description = "所在子流程ID")
  private String subProcessId;

  /**
   * 来源类型编码
   */
  @TableField(value = "source_type_code")
  @NotNull(message = "来源类型编码不能为空")
  @Schema(description = "来源类型编码")
  private String sourceTypeCode;

  /**
   * 业务场景编码
   */
  @TableField(value = "biz_scene_code")
  @NotNull(message = "业务场景编码不能为空")
  @Schema(description = "业务场景编码")
  private String bizSceneCode;

  /**
   * 是否完成 TRUE:是 FALSE:否
   */
  @TableField(value = "is_complete")
  @NotNull(message = "是否完成不能为空")
  @Schema(description = "是否完成")
  private String isComplete;

  /**
   * 父内容表主键ID
   */
  @TableField(value = "parent_entity_id")
  @Schema(description = "父内容表主键ID")
  private String parentEntityId;

  /**
   * 关联项目结项报告ID
   */
  @TableField(value = "cycle_stage_data_id")
  @Schema(description = "关联项目结项报告ID")
  private String cycleStageDataId;

  /**
   * 关联项目预算账户ID
   */
  @TableField(value = "project_account_id")
  @Schema(description = "关联项目预算账户ID")
  private String projectAccountId;

  /**
   * 操作人就职记录ID
   */
  @TableField(value = "operation_induction_id")
  @NotNull(message = "操作人就职记录ID不能为空")
  @Schema(description = "操作人就职记录ID")
  private String operationInductionId;

  /**
   * 项目logo
   */
  @TableField(value = "project_logo")
  @Schema(description = "项目logo")
  private String projectLogo;

  /**
   * 完成情况 AHEAD_SCHEDULE:提前完成（提前24h） NORMAL_COMPLETE:正常完成 OVERDUE_COMPLETE:逾期完成
   */
  @TableField(value = "complete_status")
  @Schema(description = "完成情况")
  private String completeStatus;

  /**
   * 主题内容类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "theme_content_type_code")
  @Schema(description = "主题内容类型编码")
  private String themeContentTypeCode;

  /**
   * 项目预算是否纳入部门预算 TRUE:是 FALSE:否
   */
  @TableField(value = "project_budget_is_dept")
  @Schema(description = "项目预算是否纳入部门预算")
  private String projectBudgetIsDept;

  /**
   * 创建人就职记录ID
   */
  @TableField(value = "create_induction_id")
  @NotNull(message = "创建人就职记录ID不能为空")
  @Schema(description = "创建人就职记录ID")
  private String createInductionId;

  /**
   * 总时长
   */
  @TableField(value = "total_length")
  @Schema(description = "总时长")
  private Long totalLength;

  /**
   * 项目文字描述
   */
  @TableField(value = "project_desc")
  @Schema(description = "项目文字描述")
  private String projectDesc;

  /**
   * 开始时间偏差天数
   */
  @TableField(value = "deflection_start_days")
  @Schema(description = "开始时间偏差天数")
  private Long deflectionStartDays;

  /**
   * 是否逾期 TRUE:是 FALSE:否
   */
  @TableField(value = "is_overdue")
  @NotNull(message = "是否逾期不能为空")
  @Schema(description = "是否逾期")
  private String isOverdue;

  /**
   * 主题内容ID
   */
  @TableField(value = "theme_content_id")
  @Schema(description = "主题内容ID")
  private String themeContentId;

  /**
   * 发布人就职记录ID
   */
  @TableField(value = "release_induction_id")
  @Schema(description = "发布人就职记录ID")
  private String releaseInductionId;

  /**
   * 项目图片描述
   */
  @TableField(value = "project_img")
  @Schema(description = "项目图片描述")
  private String projectImg;

  /**
   * 结束时间偏差天数
   */
  @TableField(value = "deflection_end_days")
  @Schema(description = "结束时间偏差天数")
  private Long deflectionEndDays;

  /**
   * 归属对象类型编码 OMS_ORG_DEPT:部门表 OMS_FRAMEWORK_SPACE:空间表 OMS_PROJECT:项目表 OMS_TASK:任务表
   */
  @TableField(value = "coord_object_type_code")
  @Schema(description = "归属对象类型编码")
  private String coordObjectTypeCode;

  /**
   * 存档人就职记录ID
   */
  @TableField(value = "archive_induction_id")
  @Schema(description = "存档人就职记录ID")
  private String archiveInductionId;

  /**
   * 前端偏差时间
   */
  @TableField(value = "deflection_time")
  @Schema(description = "前端偏差时间")
  private Long deflectionTime;

  /**
   * 归属对象ID
   */
  @TableField(value = "coord_object_id")
  @Schema(description = "归属对象ID")
  private String coordObjectId;

  /**
   * 是否作废 TRUE:是 FALSE:否
   */
  @TableField(value = "is_valid")
  @NotNull(message = "是否作废不能为空")
  @Schema(description = "是否作废")
  private String isValid;

  /**
   * 前端偏差语义提示
   */
  @TableField(value = "deflection_info")
  @Schema(description = "前端偏差语义提示")
  private String deflectionInfo;

  /**
   * 操作时间
   */
  @TableField(value = "operate_time")
  @NotNull(message = "操作时间不能为空")
  @Schema(description = "操作时间")
  private Date operateTime;

  /**
   * 内容冗余状态
   */
  @TableField(value = "state_code")
  @Schema(description = "内容冗余状态")
  private String stateCode;

  /**
   * 创建时间
   */
  @TableField(value = "create_time")
  @NotNull(message = "创建时间不能为空")
  @Schema(description = "创建时间")
  private Date createTime;

  /**
   * 发布时间
   */
  @TableField(value = "release_time")
  @Schema(description = "发布时间")
  private Date releaseTime;

  /**
   * 创建于空间ID
   */
  @TableField(value = "space_id")
  @NotNull(message = "创建于空间ID不能为空")
  @Schema(description = "创建于空间ID")
  private String spaceId;

  /**
   * 创建于联盟应用ID
   */
  @TableField(value = "app_id")
  @NotNull(message = "创建于联盟应用ID不能为空")
  @Schema(description = "创建于联盟应用ID")
  private String appId;
}
